

# Advanced SOC Design Lab - Synopsys-Flow

(team work)

Jiin Lai



#### Outline

- Environment settings
- Lab Synthesis
- Lab1 Floorplan
- Lab2 Placement & Route
- Lab StarRC
- Lab PrimeTime
- Lab4 Chip Finishing
- Lab IC Validator DRC
- Lab IC Validator LVS
- Lab formality





### ASIC Design flow (cell-based)





### **Environment Settings**

- Goal: setup the EDA environment and library for your design
- Source EDA tools licence
  - Ex: source asoc.eshre

### For NTHU

Don't forget to modify this according to where you want to put this directory!

cp -R /home/course/ee5252/lab\_snps\_flow/lab\_formal\_release/lab\_formal\_release <your\_lab3\_directory>

In your -/.teshre file, add a line: source /home/course/ce5252/lab\_snps\_flow/asoc.eshre

(<update in version2> You don't need to do this; instead, please refer to the next page.)



#### <This page is added in lab-snps-flow-workbook\_NTHU版\_version2>

### For NTHU

1. In your ~/.tcshrc file, add the commands below:

```
source /usr/cadtool/user setup/08-synthesis.csh
setenv SYNOPSYS_LC_ROOT /usr/cad/synopsys/lc/cur
source /usr/cadtool/user_setup/08-primetime.csh
source /usr/cadtool/user setup/08-verdi.csh
source /usr/cad/synopsys/CIC/astro.cshrc
source /usr/cadtool/user setup/08-tmax.csh
source /usr/cadtool/user setup/03-ic.csh
source /usr/cadtool/mentor/cic setup/calibre ixl 2021.csh
source /usr/cadtool/user setup/03-confrml.csh
source /usr/cadtool/user setup/03-innovus.csh
source /usr/cadtool/user setup/08-hspice.csh
source /usr/cadtool/user_setup/03-assura.csh
source /usr/cadtool/user setup/08-spyglass.csh
source /usr/cadtool/user setup/08-vcs.csh
source /usr/cadtool/user_setup/08-icc2.csh
source /usr/cad/synopsys/CIC/icc.csh
setenv ICV HOME DIR "/usr/cadtool/cad/synopsys/icvalidator/2021.06"
set path = (/usr/cadtool/cad/synopsys/icvalidator/2021.06/bin/LINUX.64 $path)
source /usr/cadtool/user setup/08-star-rcxt.csh
source /usr/cadtool/user_setup/08-formality.csh
source /usr/cadtool/user setup/05-catapult.csh
source /usr/cadtool/user_setup/05-questasim.csh
```

2. Log out EE workstation, and log in again, in order to reload .tcshrc file.



### **Environment Settings**

- Directory: ./lab\_formal\_release/common/common.tcl
  - set DESIGN\_REF\_PATH "lib path>/SAED14\_EDK\_LAB"
  - lib path>: confirm with the TA
- Directory: ./lab\_formal\_release/common/common\_setup.tcl
  - set DESIGN\_REF\_PATH "lib path>/SAED14\_EDK\_LAB"
  - lib path>: confirm with the TA

### For NTHU

path is "/home/course/ee5252/lab\_snps\_flow/SAED14\_EDK\_LAB/SAED14\_EDK\_LAB"
Please modify the above files according to this path.



### Lab Synthesis

Goal: analyze and synthesis HDL code from RTL to gate-netlist



### Lab1 Floorplan

Goal: design initiation and chip floorplan





#### Lab2 Placement & Route

## For NTHU

If it encounters a fatal error (Internal system error, Error code=6), please try to use another "ws" server, like ws27.

Goal: macro/std-cell placement and route





#### Lab StarRC

 Goal: extract the information of parasitic devices for simulation and analysis





#### Lab PrimeTime



Please change from 「/bin/tclsh」 to 「tclsh」 in /lab\_pt/work/Makefile

Goal: Static Timing Analysis and Power analysis





### Lab4 Chip Finishing

Goal: insert filler and export GDSII file for chip tap out





#### Lab IC Validator - DRC

Goal: verify Design Rule Check for the target technology





#### Lab IC Validator - DRC

- Directory: ./lab\_formal\_release/lab\_icv\_drc/work/Makefile
  - TECH\_DIR = <lib path>/SAED14\_EDK\_LAB/tech
  - path>: confirm with the TA

### For NTHU

Please modify as TECH\_DIR = /home/course/ee5252/lab\_snps\_flow/SAED14\_EDK\_LAB/SAED14\_EDK\_LAB/tech



#### Lab IC Validator - LVS

• Goal: verify Layout Versus Schematic matching the design



LVS procedure: (a) cell layout, (b) extracted schematic, and (c) targeted schematic



### Lab formality

Goal: verify the behavior of circuit and layout that





### Lab formality

- Directory: ./lab\_formal\_release/lab\_formal/script/run\_formality\_cmd.tcl
- read\_verilog -r \
   <absolute path>/lab\_formal\_release/lab\_formal/work/../../input/i2c\_master\_top.v -work\_library WORK
- read\_verilog -i \
   <absolute path>/lab\_formal\_release/lab\_formal/work/../../results/i2c\_master\_top.pt.v.gz

### For NTHU

In addition to the above two modifications, you also need to:

- 1. change from 「/bin/tclsh」 to 「tclsh」 in /lab\_formal/work/Makefile
- 2. change from 「FM\_EXEC = fm\_shell」 to 「FM\_EXEC = /usr/cad/synopsys/formality/2021.06/bin/fm\_shell」 in /lab formal/work/Makefile



#### You need to do ...

- cd directory: ./lab\_formal\_release/lab\_xxx/work
- Run the Makefile in the entire design flow
  - make all
    - Run all scripts in this stage
  - make clean
    - Clear whole results



#### Submission

- Please submit the following files to {NTHU eeclass / NTU COOL / NYCU E3} before 2024/4/28:
  - report\_TeamID.pdf
  - 2. Report contents must include the description of command in scripts (tcl file)
  - 3. The screenshot of every stage in design flow
  - 4. Discussion and observation

